package exclusiveor;

import org.junit.jupiter.api.Test;

import java.util.Arrays;

/**
 * 题目：要求在不申请额外空间变量的情况下，交换数组中两个数的位置。
 */
public class XORSwap {

    /**
     * 在不额外申请临时空间变量的情况下做到交换的效果
     */
    private static void xorSwap(int[] arr, int i, int i1) {
        arr[i] = arr[i] ^ arr[i1];
        arr[i1] = arr[i] ^ arr[i1];
        arr[i] = arr[i] ^ arr[i1];
    }

    @Test
    public void client() {
        int[] arr = new int[]{1, 2, 3};
        for (int i = 0; i < arr.length; i++) {
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[i] < arr[j]) {
                    xorSwap(arr, i, j);
                }
            }
        }
        System.out.println(Arrays.toString(arr));
    }
}
